package gdut.edu.demo04;

import java.util.Arrays;

/**
 * @Description 选择排序
 * @Author JiaFu
 * @Date 2022/11/10 19:27
 */
public class SelectSort {
    public static void main(String[] args) {
        int[] arr = new int[]{2, 4, 1, 5, 7, 9, 3, 55, 0};
        selectSort(arr);
        System.out.println(Arrays.toString(arr));
    }

    public static void selectSort(int[] arr) {
        //遍历所有的数
        for (int i = 0; i < arr.length; i++) {
            //取当前数为基准(记录其下标)
            int minIndex = i;
            //循环找出当前下标后面所有的数当中最小的那个数字的下标
            for (int j = i + 1; j < arr.length; j++) {
                //如果找到比基准数小的数，更换最小数下标
                if (arr[j] < arr[minIndex]) {
                    minIndex = j;
                }
            }
            //如果基准下标改变，后面的数字有比基准数字小的，需要交换
            if (i != minIndex) {
                int temp = arr[i];
                arr[i] = arr[minIndex];
                arr[minIndex] = temp;
            }
        }
    }
}
